class Solution {
public:
    vector<int> maxSlidingWindow(vector<int>& nums, int k) {
        deque<int> d;
        vector<int> ans;
        for(int i=0; i<k; ++i) {
            while(!d.empty() && nums[i] > nums[d.back()]) d.pop_back();
            d.push_back(i);
        }
        ans.push_back(nums[d.front()]);
        for(int i=k; i<nums.size(); ++i) {
            if(i - d.front() >= k) d.pop_front();
            while(!d.empty() && nums[i] >= nums[d.back()]) d.pop_back();
            d.push_back(i);
            ans.push_back(nums[d.front()]);
        }
        return ans;
 
    }
};